/**
 * All Types Meta Box Class JS
 *
 * JS used for the custom metaboxes and other form items.
 *
 * Copyright 2011 - 2013 Ohad Raz (admin@bainternet.info)
 * @since 1.0
 */

var $ = jQuery.noConflict();

var e_d_count = 0;
var Ed_array = Array;
//fix editor on window resize
jQuery(document).ready(function ($) {
	//editor rezise fix
	$(window).resize(function () {
		$.each(Ed_array, function () {
			var ee = this;
			$(ee.getScrollerElement()).width(100); // set this low enough
			width = $(ee.getScrollerElement()).parent().width();
			$(ee.getScrollerElement()).width(width); // set it to
			ee.refresh();
		});
	});
});
function update_repeater_fields() {
	_metabox_fields.init();
}
//metabox fields object
var _metabox_fields = {
	oncefancySelect: false,
	init: function () {
		if (!this.oncefancySelect) {
			this.fancySelect();
			this.oncefancySelect = true;
		}
		this.load_conditinal();
		this.load_time_picker();
		this.load_date_picker();
		this.load_color_picker();

		// repater Field
		$(".at-re-toggle").live('click', function () {
			$(this).parent().find('.repeater-table').toggle('slow');
		});
		// repeater sortable
		$('.repeater-sortable').sortable({
			opacity: 0.6,
			revert: true,
			cursor: 'move',
			handle: '.at_re_sort_handle',
			placeholder: 'at_re_sort_highlight'
		});
		//$('.repeater-sortable').sortable( "option", "handle", ".at_re_sort_handle" );
	},
	fancySelect: function () {
		if ($().select2) {
			$(".at-select, .at-posts-select, .at-tax-select").each(function () {
				if (!$(this).hasClass('no-fancy'))
					$(this).select2();
			});
		}
	},
	get_query_var: function (name) {
		var match = RegExp('[?&]' + name + '=([^&#]*)').exec(location.href);
		return match && decodeURIComponent(match[1].replace(/\+/g, ' '));
	},
	load_conditinal: function () {
		$(".conditinal_control").click(function () {
			if ($(this).is(':checked')) {
				$(this).next().show('fast');
			} else {
				$(this).next().hide('fast');
			}
		});
	},
	load_time_picker: function () {
		$('.at-time').each(function () {

			var $this = $(this),
				format = $this.attr('rel'),
				aampm = $this.attr('data-ampm');
			if ('true' == aampm)
				aampm = true;
			else
				aampm = false;

			$this.timepicker({ showSecond: true, timeFormat: format, ampm: aampm });

		});
	},
	load_date_picker: function () {
		$('.at-date').each(function () {

			var $this = $(this),
				format = $this.attr('rel');

			$this.datepicker({ showButtonPanel: true, dateFormat: format });

		});
	},
	load_color_picker: function () {
		if ($('.at-color-iris').length > 0)
			$('.at-color-iris').wpColorPicker();
	},
};
//call object init in delay
window.setTimeout('_metabox_fields.init();', 2000);

//upload fields handler
var simplePanelmedia;
jQuery(document).ready(function ($) {
	var simplePanelupload = (function () {
		var inited;
		var file_id;
		var file_url;
		var file_type;

		function init() {
			return {
				image_frame: new Array(),
				file_frame: new Array(),
				hooks: function () {
					$(document).on('click', '.simplePanelimageUpload,.simplePanelfileUpload', function (event) {
						event.preventDefault();
						if ($(this).hasClass('simplePanelfileUpload'))
							inited.upload($(this), 'file');
						else
							inited.upload($(this), 'image');
					});

					$('.simplePanelimageUploadclear,.simplePanelfileUploadclear').live('click', function (event) {
						event.preventDefault();
						inited.set_fields($(this));
						$(inited.file_url).val("");
						$(inited.file_id).val("");
						if ($(this).hasClass('simplePanelimageUploadclear')) {
							inited.set_preview('image', false);
							inited.replaceImageUploadClass($(this));
						} else {
							inited.set_preview('file', false);
							inited.replaceFileUploadClass($(this));
						}
					});
				},
				set_fields: function (el) {
					inited.file_url = $(el).prev();
					inited.file_id = $(inited.file_url).prev();
				},
				upload: function (el, utype) {
					inited.set_fields(el)
					if (utype == 'image')
						inited.upload_Image($(el));
					else
						inited.upload_File($(el));
				},
				upload_File: function (el) {
					// If the media frame already exists, reopen it.
					var mime = $(el).attr('data-mime_type') || '';
					var ext = $(el).attr("data-ext") || false;
					var name = $(el).attr('id');
					var multi = ($(el).hasClass("multiFile") ? true : false);

					if (typeof inited.file_frame[name] !== "undefined") {
						if (ext) {
							inited.file_frame[name].uploader.uploader.param('uploadeType', ext);
							inited.file_frame[name].uploader.uploader.param('uploadeTypecaller', 'my_meta_box');
						}
						inited.file_frame[name].open();
						return;
					}
					// Create the media frame.

					inited.file_frame[name] = wp.media({
						library: {
							type: mime
						},
						title: jQuery(this).data('uploader_title'),
						button: {
							text: jQuery(this).data('uploader_button_text'),
						},
						multiple: multi  // Set to true to allow multiple files to be selected
					});


					// When an image is selected, run a callback.
					inited.file_frame[name].on('select', function () {
						// We set multiple to false so only get one image from the uploader
						attachment = inited.file_frame[name].state().get('selection').first().toJSON();
						// Do something with attachment.id and/or attachment.url here
						$(inited.file_id).val(attachment.id);
						$(inited.file_url).val(attachment.url);
						inited.replaceFileUploadClass(el);
						inited.set_preview('file', true);
					});
					// Finally, open the modal

					inited.file_frame[name].open();
					if (ext) {
						inited.file_frame[name].uploader.uploader.param('uploadeType', ext);
						inited.file_frame[name].uploader.uploader.param('uploadeTypecaller', 'my_meta_box');
					}
				},
				upload_Image: function (el) {
					var name = $(el).attr('id');
					var multi = ($(el).hasClass("multiFile") ? true : false);
					// If the media frame already exists, reopen it.
					if (typeof inited.image_frame[name] !== "undefined") {
						inited.image_frame[name].open();
						return;
					}
					// Create the media frame.
					inited.image_frame[name] = wp.media({
						library: {
							type: 'image'
						},
						title: jQuery(this).data('uploader_title'),
						button: {
							text: jQuery(this).data('uploader_button_text'),
						},
						multiple: multi  // Set to true to allow multiple files to be selected
					});
					// When an image is selected, run a callback.
					inited.image_frame[name].on('select', function () {
						// We set multiple to false so only get one image from the uploader
						attachment = inited.image_frame[name].state().get('selection').first().toJSON();
						// Do something with attachment.id and/or attachment.url here
						$(inited.file_id).val(attachment.id);
						$(inited.file_url).val(attachment.url);
						inited.replaceImageUploadClass(el);
						inited.set_preview('image', true);
					});
					// Finally, open the modal
					inited.image_frame[name].open();
				},
				replaceImageUploadClass: function (el) {
					if ($(el).hasClass("simplePanelimageUpload")) {
						$(el).removeClass("simplePanelimageUpload").addClass('simplePanelimageUploadclear').val('Remove Image');
					} else {
						$(el).removeClass("simplePanelimageUploadclear").addClass('simplePanelimageUpload').val('Upload Image');
					}
				},
				replaceFileUploadClass: function (el) {
					if ($(el).hasClass("simplePanelfileUpload")) {
						$(el).removeClass("simplePanelfileUpload").addClass('simplePanelfileUploadclear').val('Remove File');
					} else {
						$(el).removeClass("simplePanelfileUploadclear").addClass('simplePanelfileUpload').val('Upload File');
					}
				},
				set_preview: function (stype, ShowFlag) {
					ShowFlag = ShowFlag || false;
					var fileuri = $(inited.file_url).val();
					if (stype == 'image') {
						if (ShowFlag)
							$(inited.file_id).prev().find('img').attr('src', fileuri).show();
						else
							$(inited.file_id).prev().find('img').attr('src', '').hide();
					} else {
						if (ShowFlag)
							$(inited.file_id).prev().find('ul').append('<li><a href="' + fileuri + '" target="_blank">' + fileuri + '</a></li>');
						else
							$(inited.file_id).prev().find('ul').children().remove();
					}
				}
			}
		}

		return {
			getInstance: function () {
				if (!inited) {
					inited = init();
				}
				return inited;
			}
		}
	})()
	simplePanelmedia = simplePanelupload.getInstance();
	simplePanelmedia.hooks();
});